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(54) Waiting-call selection based on anticipated wait times 



(57) The maximum wait time for callers in a call cent- 
er is lowered by selecting, for an agent who has just be- 
come available to handle a call, a highest-priority waiting 
call that would most likely wait the longest if it were not 
selected at this time. Anticipated wait times are comput- 
ed for the calls at the heads of the non-empty highest- 
priority call queues that correspond to the agent's skills 



or splits (202-210). The anticipated wait time of a call is 
computed as the call's present (elapsed) wait time plus 
the average rate of advance of calls in the call's queue 
(210). The call with the longest anticipated wait time is 
then selected first and is assigned to the available agent 
for handling (212-216). The process is repeated each 
time that any agent becomes available. 
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Description 

Technical Fi Id 

This invention relates to queuing arrangements, for 
example to telephone call-answering centers and auto- 
matic call-distribution systems. 

Background of the Invention 

In automatic call-distribution (ACD) systems, calls 
incoming to a call center are answered and handled by 
a plurality of agents. The ACD system automatically dis- 
tributes and connects incoming calls to whatever agents 
are suited to handle the calls and are free, that is, not 
handling other calls at the moment. 

It often happens that the call center becomes over- 
loaded by calls, so that no suitable agents are available 
to handle calls at the moment that the calls come in. The 
calls then back up. They are placed in different queues 
based upon some preestablished criteria, and are 
placed in each queue in the order of their arrival and/or 
priority. There they await suitable agents becoming free 
and available to service them. The waiting calls are dis- 
tributed to agents for handling on an oldest-call-waiting 
(OCW) basis. That is, when an agent becomes availa- 
ble, the system considers the call at the head of each 
queue from which that agent is eligible to handle a call, 
and selects the one of the calls that has been waiting 
the longest. The system does not consider how long a 
call will have to wait for the next available agent if the 
call is not selected at this time. 

Summary of the Invention 

The inventors have realized that the additional wait 
time of each call that is not presently selected repre- 
sents a cost, expressed for example in caller frustration 
and call abandonment, to the ACD system's client (the 
called party). They have further realized that they can 
lower the overall average speed of call answer, and 
thereby lower the abovementioned cost, by selecting, 
for the agent who has just become available, the call 
that would most likely wait the longest if it were not se- 
lected at this time. For example, if a call queue corre- 
sponding to a main, large, skill possessed by many 
agents has a present elapsed wait time of one minute 
and a call rale of advance lime of 10 seconds, the total 
anticipated wait time is 70 seconds for the oldest call in 
that queue. If a call queue corresponding to a special- 
ized, small, skill possessed by few agents has a present 
elapsed wait time of 50 seconds and a call rate of ad- 
vance of 25 seconds (since only a few agents have the 
skill), the total anticipated wait time is 75 seconds for 
the oldest call in that queue. According to the invention, 
a call from the queue corresponding to the specialized 
skill would be selected for an available agent who has 
both skills, even though the presently-oldest waiting call 



is in the queue corresponding to the main skill. Such call 
distribution not only lowers the average overall speed of 
answer, it also provides improved service to call types 
that only a few agents can handle or that require a long 

5 talk time (i.e., that have a low call rate of advance). 

Generally according to the invention, therefore, 
there is provided a method of and an apparatus for se- 
lecting one of a plurality of items (e.g., calls) that are 
waiting to be selected. The method comprises the steps 

10 of anticipating how long each one of the plurality of items 
that are waiting to be selected will have waited to be 
selected if said item is not selected first from among the 
waiting items, and first selecting the one of the waiting 
items that has a longest anticipated wait time. Preferably 

*5 these steps are repeated until only one item of the plu- 
rality ol items remains waiting to be selected. The ap- 
paratus effects the method steps. It preferably includes 
an effector —any entity that effects the corresponding 
step, unlike a means-for each method step. Further ac- 

20 cording to the invention, there is provided a computer- 
readable medium containing software which, when ex- 
ecuted in a computer, causes the computer to perform 
the method steps. 

If the plurality of waiting items are communications 

25 that are waiting to be processed (e.g., handled by 
agents), the method comprises the steps of anticipating 
how long each one of the plurality of communications 
that are waiting to be processed will have waited before 
being processed if said communication is not processed 

30 first from among the waiting communications, and first 
processing the one of the waiting communications that 
has a longest anticipated wait time. The apparatus and 
the executing software again effect the method steps. 
These and other advantages and features of the in- 

35 vention will become more apparent from the following 
description of an illustrative embodiment of the invention 
taken together with the drawing. 

Brief Description of the Drawing 

40 

FIG. 1 is a block diagram of a call center that in- 
cludes an illustrative embodiment of the invention; 
and 

FIG. 2 is a flow diagram of operations of the SEL 
45 function of the call center of FIG. 1 . 

Detailed Description 

FIG. 1 shows an illustrative call center that compris- 
50 es an automatic call-distribution (ACD) switch 10 serv- 
ing a plurality of agent stations 11 at least some of which 
are staffed by agents 25. ACD switch 10 is connected 
to a plurality of trunks 1 2 over which it receives incoming 
calls. It then distributes and connects these calls to sta- 
55 tions 11 of available agents 25 based on a set of prede- 
termined criteria. The agents process calls sent to them 
by ACD switch 10. The call center of FIG. 1 is illustra- 
tively the subscriber-premises equipment disclosed in 
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U.S. Patent No. 5,206,903. 

ACD switch 10 is also served by a pair of adjunct 
processors 13 and 14. Call management system (CMS) 

13 provides a call accounting, reporting, and manage- 
ment capability, and a voice information system (VIS) 

14 provides an announcements capability. Both adjunct 
processors 13 and 14 are conventional. CMS 13 is illus- 
tratively the Lucent Technologies CMS, and VIS 14 is 
illustratively the Lucent Technologies Conversant® VIS. 
As is conventional, ACD system 10 is a stored-program- 
controlled unit that includes a memory 15 comprising 
one or more different memory units for storing programs 
and data, and a processor 16 for executing the stored 
programs and using the stored data in their execution. 
The memory includes a plurality of sets 20 of call queues 
21. Each set 20 of call queues 21 conventionally serves 
and holds calls for a different split or skill group of 
agents. Within each set 20 of call queues 21, each 
queue 21 holds calls of a different priority. Alternatively, 
each set 20 comprises only one call queue 21 in which 
calls of different priority are enqueued in their order of 
priority. Calls are assigned different priorities in a known 
manner based upon some predefined criteria such as, 
for example, whether the caller is an unknown person, 
a regular account holder, or a preferred customer. Each 
queue 21 functions as a first-in, first-out (FIFO) buffer 
memory, and includes a plurality of entries, or positions 
23, each for identifying a corresponding one enqueued 
call. The position 23 at the head of queue 21 is consid- 
ered to be position number 1 , the next subsequent po- 
sition 23 in queue 21 is considered to be position 
number 2, etc. 

Memory 15 further includes an estimated wait time 
(EWT) function 22. As its name implies, this function de- 
termines an estimate of how long a call that is placed in 
a queue 21 will have to wait before being connected to 
a station 11 for servicing. The estimate is derived sep- 
arately by EWT function 22 for each queue 21 of each 
set 20. It is based on the average rate of advance of 
calls through positions 23 of the calls' corresponding 
queue 21; this rate of advance is computed by EWT 
function 22. An illustrative implementation of EWT func- 
tion 22 is disclosed in U.S. Patent No. 5,506,898. 

Memory 15 further includes a call-selection (SEL) 
function 24. Function 24 is conventional in that, for each 
call at the head of a queue 21, it determines how long 
the call has been in the queue (the call's present wait 
lime, or PWT), and in that, for each available agent 25, 
it selects a call from queues 21 for connection to and 
handling by that agent 25. According to the invention, 
however, SEL function 24 does not select calls on an 
oldest (highest PWT) -call -waiting basis. Rather, when 
an agent 25 becomes available, SEL function 24 con- 
siders the call at the head of each queue 21 from which 
that agent is eligible to handle a call, and selects the 
highest-priority one of the calls that would most likely 
wait the longest if it were not selected at this time. This 
functionality of SEL function 24 is flowcharted in FIG. 2. 



Execution of SEL function 24 is invoked each time 
that an agent 25 becomes available to handle a call, at 
step 200 of FIG. 2. In response, SEL function 24 deter- 
mines, from the agent's stored profile, the skills to which 

s agent 25 is assigned, at step 202. SEL function 24 then 
determines the highest priority of any calls that are wait- 
ing for any of the determined skills. Illustratively, for each 
of the agent's skills, SEL function 24 selects the corre- 
sponding set 20 of call queues 21 and determines the 

io highest-priority call queue 21 in that set 20 which con- 
tains at least one call, and then determines the priority 
of the highest-priority one of the determined call queues 
21 . SEL function 22 then selects those determined call 
queues 21 which have the highest priority and computes 

15 the anticipated wait times for those selected queues 21 , 
as follows. 

For the call at the head of each of the determined 
highest-priority call queues 21 , SEL function determines 
how long that call has been in queue (i.e., determines 

20 the call's present wail time), in a conventional manner, 
at step 206. For each of those calls, SEL function 24 
also obtains from EWT function 22 the average rate of 
advance of calls in the corresponding call queue 21 , at 
step 208. SEL function 24 further sums the two quanti- 

25 ties obtained for each of the calls at steps 206 and 208 
to compute each call's anticipated wait time, at step 210. 
Alternatively, the average rate of advance may be ad- 
justed prior to summing, by subtracting therefrom one- 
half of the time since the last call was removed from the 

30 corresponding call queue and summing the result or 
25% of the unadjusted average rate of advance - which- 
ever is greater - with the present wait time. SEL function 
24 then compares the computed anticipated wait times 
and selects the call that has the longest anticipated wait 

35 time, at step 212, and assigns the selected call to the 
agent 25 who became available at step 200, at step 21 6. 
SEL function 24 then ends execution, at step 218, until 
an agent 25 becomes available again. 

Of course, various changes and modifications to the 

40 illustrative embodiment described above will be appar- 
ent to those skilled in the art. For example, when there 
are not enough calls to keep the agents busy and the 
agents queue up to wait for calls, the same algorithm 
can be used to determine which agent should take the 

45 next incoming call. Or, the SEL function may be per- 
formed by an adjunct processor that is connected to and 
controls the ACD switch via computer telephony inte- 
gration (CTI). Also, application of the invention is not lim- 
ited to distribution of real-time calls; it may also be ap- 

50 plied to the queuing and distribution of stored requests 
sent or left by requestors, such as e-mail, voice mail, 
fax, video/voice recordings, and multimedia messages. 
The concept of AWT routing is also applicable to work- 
flow applications that route work items among people or 

55 stations qualified to do the next piece of the overall work, 
and to shop-floor scheduling. Such changes and modi- 
fications can be made without departing from the spirit 
and the scope of the invention and without diminishing 
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its attendant advantages. It is therefore intended that 
such changes and modifications be covered by the fol- 
lowing claims. 

Claims 

1 . A method of selecting one of a plurality of items that 
are waiting to be selected, CHARACTERISED BY 
the steps of: 

anticipating (204-2 1 0) how long each one of the 
plurality of items that are waiting to be selected 
will have waited to be selected if said item is 
not selected first from among the waiting items; 
and 

first selecting (21 2) the one of the waiting items 
that has a longest anticipated wait time. 

2. The method of claim 1 wherein: 

the step of anticipating comprises the steps of 
determining (206) how long each one of the plu- 
rality of items has been waiting to be selected, 
determining (208) how long each one of the plu- 
rality of items is likely to wait to be selected if 
said item is not selected first, and 
for each one of the items, combining (210) the 
determinations made for said item to obtain the 
anticipated wait time for said item. 

3. The method of claim 1 for selecting one of a plurality 
of items from a plurality of queues (21 ) each having 
at least one enqueued item (23), wherein: 

the step of anticipating comprises the step of 
anticipating (206) how long each item that is en- 
queued at a head of any of the queues will have 
waited to be selected if said item is not selected 
first from among the items that are enqueued 
at the heads of the plurality of the queues. 

4. The method of claim 1 wherein: 

the plurality of items are waiting to be selected 
for processing, and 

the first-selected item is selected for being 
processed (206) first from among the waiting 
items. 

5. The method of claim 1 wherein: 

the items are communications that are waiting 
to be processed; 

the step of anticipating comprises the step of 
anticipating (204-2 1 0) how long each one of the 
plurality of communications that are waiting to 
be processed will have waited before being 



processed if said communication is not proc- 
essed first from among the waiting communi- 
cations; and 

the step of selecting comprises the step of 
$ first processing (21 2-216) the one of the waiting 

communications that has a longest anticipated 
wait time. 

6. The method of claim 5 for selecting for processing 
10 one of a plurality of communications from a plurality 

of queues (21) each having at least one enqueued 
communication, wherein: 

the step of anticipating comprises the step of 
is anticipating (204-210) how long each commu- 

nication that is enqueued at a head of any of 
the queues will have waited to be processed if 
said communication is not processed first from 
among the communications that are enqueued 
20 at the heads of the plurality of the queues. 

7. The method of claim 6 wherein: 

the step of anticipating how long each commu- 
25 nication that is enqueued at a head of any of 

the queues will have waited comprises the 
steps of 

determining (206) how long each one of the plu- 
rality of the communications that are enqueued 
30 at the heads of the queues have been en- 

queued, 

determining (208) how long each one of the plu- 
rality of the communications that are enqueued 
at the heads of the queues is likely to remain 
35 enqueued if said communication is not proc- 

essed first, and 

for each one of the plurality of the communica- 
tions that are enqueued at the heads of the 
queues, combining (210) the determinations 
40 made for said communication to obtain the an- 

ticipated wait time for said communication. 

8. The method of claim 7 wherein: 

45 the step of determining how long each one of 

the plurality of the communications is likely to 
remain enqueued comprises the step of 
determining (208) for each of the queues a rate 
of advance of enqueued communications 

50 through the queue. 

9. The method of claim 6 wherein: 

each one of the queues (21) corresponds to a 
55 different skill or split, and 

the step of anticipating comprises the steps of 
in response to an agent becoming available 
(200) to process a communication, determining 
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(202) skills or spirts that correspond to the 
agent; 

in response to determining the skills or splits 
that correspond to the agent, anticipating 
(204-210) how long each communication that s 
is enqueued at a head of any of the queues that 
correspond to the skills or splits that corre- 
spond to the agent will have waited to be proc- 
essed if said communication is not processed 
first from among the communications that are 10 
enqueued at the heads of the queues that cor- 
respond to the skills or splits that correspond to 
the agent. 

10. An apparatus that effects the steps of claim 1 or 2 15 
or 3 or 4 or 5 or 6 or 7 or 8 or 9. 
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(54) Waiting-call selection based on anticipated wait times 



(57) The maximum wait time for callers in a call cent- 
er is lowered by selecting, for an agent who has just be- 
come available to handle a call, a highest-priority waiting 
call that would most likely wait the longest if it were not 
selected at this time. Anticipated wait times are comput- 
ed for the calls at the heads of the non-empty highest- 
priority call queues that correspond to the agent's skills 



or splits (202-210). The anticipated wait time of a call is 
computed as the call's present (elapsed) wait time plus 
the average rate of advance of calls in the call's queue 
(210). The call with the longest anticipated wait time is 
then selected first and is assigned to the available agent 
for handling (212-216). The process is repeated each 
time that any agent becomes available. 
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